//输入两棵二叉树A和B，判断B是不是A的子结构。(约定空树不是任意一个树的子结构) 
//
// B是A的子结构， 即 A中有出现和B相同的结构和节点值。 
//
// 例如: 
//给定的树 A: 
//
// 3 
// / \ 
// 4 5 
// / \ 
// 1 2 
//给定的树 B： 
//
// 4 
// / 
// 1 
//返回 true，因为 B 与 A 的一个子树拥有相同的结构和节点值。 
//
// 示例 1： 
//
// 输入：A = [1,2,3], B = [3,1]
//输出：false
// 
//
// 示例 2： 
//
// 输入：A = [3,4,5,1,2], B = [4,1]
//输出：true 
//
// 限制： 
//
// 0 <= 节点个数 <= 10000 
// Related Topics 树 
// 👍 151 👎 0

package leetcode.editor.cn;
//Java：树的子结构
public class ShuDeZiJieGouLcof{
    public static void main(String[] args) {
        Solution solution = new ShuDeZiJieGouLcof().new Solution();
        
    }
    class TreeNode {
      int val;
      TreeNode left;
      TreeNode right;
      TreeNode(int x) { val = x; }
    }
    //leetcode submit region begin(Prohibit modification and deletion)
/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode(int x) { val = x; }
 * }
 */
class Solution {
    public boolean isSubStructure(TreeNode A, TreeNode B) {
        if ( A == null || B == null ){
            return false;
        }
        boolean answer = false;
        if ( A.val == B.val ){
            answer = checkAhasB( A,B );
        }

        if ( !answer ){
            answer = isSubStructure( A.left, B );
        }
        if ( !answer ){
            answer = isSubStructure( A.right,B );
        }
        return  answer;
    }

    private boolean checkAhasB( TreeNode A, TreeNode B ){
        if ( B == null ){
            return true;
        }
        if ( A == null ){
            return false;
        }
        if ( A.val != B.val ){
            return false;
        }
        return checkAhasB(A.left,B.left) && checkAhasB(A.right,B.right);

    }
}
//leetcode submit region end(Prohibit modification and deletion)

}
